<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>BEGIN</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="REFENTRY">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="sql-analyze.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="sql-analyze.html">快退</a></td><td width="60%" align="center" valign="bottom"></td><td width="10%" align="right" valign="top"><a href="sql-checkpoint.html">快进</a></td><td width="10%" align="right" valign="top"><a href="sql-checkpoint.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<h1><a name="SQL-BEGIN"></a>BEGIN</h1>
<div class="REFNAMEDIV"><a name="AEN45564"></a><h2>名称</h2>BEGIN&nbsp;--&nbsp;开始一个事务块</div>
<a name="AEN45567"></a>
<div class="REFSYNOPSISDIV"><a name="AEN45569"></a><h2>语法</h2>
<pre class="SYNOPSIS">BEGIN [ WORK | TRANSACTION ] [ <tt class="REPLACEABLE"><i>transaction_mode</i></tt> [, ...] ]

这里的 <tt class="REPLACEABLE"><i>transaction_mode</i></tt> 是下列之一：

    ISOLATION LEVEL { SERIALIZABLE | REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED }
    READ WRITE | READ ONLY</pre>
</div>
<div class="REFSECT1"><a name="AEN45573"></a><h2>描述</h2>
<p><tt class="COMMAND">BEGIN</tt> 初始化一个事务块，也就是说所有 <tt class="COMMAND">BEGIN</tt> 命令后的用户语句都将在一个事务里面执行直到给出一个明确的 <a href="sql-commit.html"><i>COMMIT</i></a> 或 <a href="sql-rollback.html"><i>ROLLBACK</i></a> 。缺省时(没有 <tt class="COMMAND">BEGIN</tt>)，PostgreSQL 以"autocommit"模式执行事务，也就是说，每个语句在其自身的事务中执行，并且在语句结束的时候，如果执行成功则隐含地执行一个提交，否则执行回滚。</p>
<p>在事务块里执行的语句很明显地快得多，因为事务开始/提交需要大量的 CPU 和磁盘活动。在一个事务内部执行多条语句对于修改若干个相关的表的时候也是很有用的：在所有相关的更新完成之前，其它会话看不到中间的状态。</p>
<p>如果声明了隔离级别或者读/写模式，那么新事务将具有那些特征。就像执行了 <a href="sql-set-transaction.html"><i>SET TRANSACTION</i></a> 一样。</p>
</div>
<div class="REFSECT1"><a name="AEN45586"></a><h2>参数</h2>
<div class="VARIABLELIST">
<dl>
<dt><tt class="LITERAL">WORK</tt><br><tt class="LITERAL">TRANSACTION</tt></dt>
<dd><p>可选关键字，没什么作用。</p></dd>
</dl>
</div>
<p>参考 <a href="sql-set-transaction.html"><i>SET TRANSACTION</i></a> 获取这个语句的其它参数的含义。</p>
</div>
<div class="REFSECT1"><a name="AEN45598"></a><h2>注意</h2>
<p><a href="sql-start-transaction.html"><i>START TRANSACTION</i></a> 有着和 <tt class="COMMAND">BEGIN</tt> 一样的功能。</p>
<p>使用 <a href="sql-commit.html"><i>COMMIT</i></a> 或 <a href="sql-rollback.html"><i>ROLLBACK</i></a> 结束一个事务块。</p>
<p>在一个现有事务块内部发出一个 <tt class="COMMAND">BEGIN</tt> 将产生一个警告信息。事务的状态将不会被影响。要想在一个事务块里嵌套事务，请使用保存点(参见 <a href="sql-savepoint.html"><i>SAVEPOINT</i></a>)。</p>
<p>出于向下兼容考虑，在随后的 <tt class="REPLACEABLE"><i>transaction_modes</i></tt> 之间的逗号可以忽略。</p>
</div>
<div class="REFSECT1"><a name="AEN45611"></a><h2>例子</h2>
<p>开始一个事务块：</p>
<pre class="PROGRAMLISTING">BEGIN;</pre>
</div>
<div class="REFSECT1"><a name="AEN45615"></a><h2>兼容性</h2>
<p><tt class="COMMAND">BEGIN</tt> 是 PostgreSQL 语言的扩展。等价于 SQL 标准中的 <a href="sql-start-transaction.html"><i>START TRANSACTION</i></a> 命令，可以参考附加的兼容性信息。</p>
<p>顺便说一句，<tt class="LITERAL">BEGIN</tt> 关键字在嵌入 SQL 里用于不同目的。建议你在移植数据库应用时仔细检查事务的语意。</p>
</div>
<div class="REFSECT1"><a name="AEN45623"></a><h2>又见</h2><a href="sql-commit.html"><i>COMMIT</i></a>, <a href="sql-rollback.html"><i>ROLLBACK</i></a>, <a href="sql-start-transaction.html"><i>START TRANSACTION</i></a>, <a href="sql-savepoint.html"><i>SAVEPOINT</i></a></div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="sql-analyze.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="sql-checkpoint.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">ANALYZE</td><td width="34%" align="center" valign="top"><a href="sql-commands.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">CHECKPOINT</td></tr>
</table>
</div>
</body></html>